## PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2000-298640

(43) Date of publication of application: 24.10.2000

(51)Int.Cl.

G06F 13/28

(21)Application number: 11-104228

(71)Applicant: RICOH CO LTD

(22)Date of filing:

12.04.1999

(72)Inventor: TANAKA SATOSHI

### (54) DMA DEVICE

#### (57)Abstract:

PROBLEM TO BE SOLVED: To facilitate to recognize what number descriptor the currently transferred block is set to, to optionally set a time internal between the 1st block transfer completion and the next block transfer start and further to facilitate to manage the generation, setting and storage of a descriptor in a program.

SOLUTION: This DMA(direct memory access) device is provided with one or more descriptors 610/620 which respectively include transfer source address information 612/622 showing transfer information blocks and transfer byte number information 612/623 and a transfer controlling means (DMAC (DMA controller)) which reads transfer information designated by the descriptors' information from memories 630/640. In such a case, the transfer controlling means generates continuous interrupt in timing shown by a timer variable for each transfer of one block based on the information of one descriptor. Then, it has 'unused' data for its management in each descriptor.



(19)日本国特許庁(JP)

## (12) 公開特許公報(A)

(11)特許出顧公開番号 特開2000-298640 (P2000-298640A)

(43)公開日 平成12年10月24日(2000.10.24)

(51) Int.Cl.7

識別記号

FΙ

テーマコート\*(参考)

G06F 13/28

310

G06F 13/28

310E 5B061

## 審査請求 未請求 請求項の数3 OL (全 6 頁)

(21)出願番号

特願平11-104228

(22)出題日

平成11年4月12日(1999.4.12)

(71)出顧人 000006747

株式会社リコー

東京都大田区中馬込1丁目3番6号

(72) 発明者 田 中 智

東京都大田区中馬込1丁目3番6号 株式

会社リコー内

(74)代理人 100076967

弁理士 杉信 興

Fターム(参考) 5B061 BA02 BA03 DD01 DD06 DD11

#### (54) 【発明の名称】 DMA装置

## (57)【要約】

【課題】 現在、転送されているブロックが何番目のディスクリプタに設定されているブロックなのかの認識を容易にする。1つ目のブロック転送完了と次のブロック転送の開始までの時間を任意に設定可とする。ディスクリプタの生成、設定、保存をプログラムにおいて管理しやすくする。

【解決手段】 それぞれが、転送情報のブロックを示す、転送元アドレス情報612/622および転送バイト数情報613/623を含む、1以上のディスクリプタ610/620;および、これらのディスクリプタの情報が指定する転送情報をメモリ630/640から読出す転送制御手段400;を備えるDMA装置において、転送制御手段は、1つのディスクリプタの情報に基づいた1ブロックの転送毎に、タイマ変数が示すタイミングで、機続割込みを発生する、ことを特徴とする。ディスクリプタ毎にその管理用の「未使用」データを有する。



### 【特許請求の範囲】

【請求項1】それぞれが、転送情報の転送単位区分を示 す、一転送単位の転送元アドレス情報および転送バイト 数情報を含む、1以上のディスクリプタ;および、これ ちのディスクリプタから順次に転送元アドレス情報およ び転送バイト数情報を読出してこれらの情報に従って転 送情報をメモリから読出す転送制御手段;を備えるDM A装置において、

前記転送制御手段は、1つのディスクリプタの情報に基 ルパー単位の転送毎に割込み信号を発生する。ことを 10 特徴とするDMA装置。

【請求項2】各ディスクリプタは割込み発生タイミング 情報を含み、転送制御手段は、1つのディスクリプタの 情報に基づいた一単位の転送毎に該ディスクリプタが保 持した割込み発生タイミング情報が指定するタイミング で割込み信号を発生する、請求項1記載のDMA装置。

【請求項3】各ディスクリプタは、それに宛てられた一 単位の転送の制御には無関係な、ディスクリプタ管理用 のデータを含む、請求項1又は請求項2記載のDMA装 置。

#### 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、ダイレクト・メモ リ・アクセス(DMA)装置に関する。

[0002]

【従来の技術】特開平7-21117号公報には、DM Aの1バスサイクル転送,2バスサイクル転送,バース ト転送およびサイクルスチール転送が説明され、バース ト転送には単転送モード,繰返し転送モード,アレイタ ェーン転送モードおよびリンクアレイ転送モードの4モ 30 - ドがあることが説明されている。

【0003】従来のディスクリプタ方式のコントローラ (DMAC)は、転送開始タイミングをカウンタのアン ダーフローを使って制御することはできたが転送終了の タイミングを遅らせることはできなかった。また、ディ スクリプタによって指定される転送対象のブロックを連 続で転送することができても、ブロック転送完了で一旦 停止し、再起動することはできなかった。

[0004]

【発明が解決しようとする課題】ディスクリプタを使っ た転送ではディスクリプタのチェーンが終了し、すべて のブロックが転送完了した場合にのみ、完了割り込みが 発生していた。しかし、ブリンタの描画処理のようにブ ロック毎の処理とブロック毎の転送を同時に行う場合、 現在、転送されているブロックが何番目のディスクリプ タに設定されているブロックなのかをプログラムが知る ことができなかった。周期的なブロック転送を異なるブ ロックに対して行うとき、転送先デバイスの処理が完了 してから、次のブロックを送る必要がある。

が何番目のディスクリプタに設定されているブロックな のかを認識するための処理を容易にすることを第1の目 的とし、1つ目のブロック転送完了と次のブロック転送 の開始までの時間を設定できるようにすることを第2の 目的とし、ディスクリプタの生成、設定、保存をプログ ラムにおいて管理しやすくすることを第3の目的とす る。

[0006]

【課題を解決するための手段】(1)それぞれが、転送 情報の転送単位区分(ブロック)を示す、一転送単位(1 ノロック)の転送元アドレス情報(612/622)および転送 バイト数情報(613/623)を含む、1以上のディスクリブ タ(610/620);および、これらのディスクリプタから順 次に転送元アドレス情報および転送バイト数情報を読出 してこれらの情報に従って転送情報をメモリ(630/640) から読出す転送制御手段(400);を備えるDMA装置に おいて、前記転送制御手段(400)は、1つのディスクリ プタの情報に基づいた一単位の転送毎に割込み信号(継 続割込み)を発生する、ことを特徴とするDMA装置。 20 なお、理解を容易にするためにカッコ内には、図面に示 し後述する実施例の対応要素の符号又は対応事項を、参

【0007】これによれば、ディスクリプタ毎に割込み 信号を発生するので、この信号に応答して、実行したデ ィスクリプタの数をカウントアップして、何番目のディ スクリプタに設定されているブロックの転送なのかを認 識するととが可能になる。また、割込み信号に応答して 次のブロックの転送を開始するか一時的に保留するかの チェックを行なって開始可のときに転送を開始するな ど、順次転送を抑制することも可能になる。

考までに付記した。以下も同様である。

[0008]

【発明の実施の形態】(2)各ディスクリプタは割込み 発生タイミング情報(モ-ドワ-ド614のタイマ変数)を含 み、転送制御手段(400)は、1つのディスクリプタの情 報に基づいた一単位の転送毎に該ディスクリプタが保持 した割込み発生タイミング情報が指定するタイミングで 割込み信号を発生する。

【0009】これによれば、割り込みのタイミングや継 続のタイミングをディスクリプタ毎に設定することがで きる。

(3) 各ディスクリプタは、それに宛てられた一単位の 転送の制御には無関係な、ディスクリプタ管理用のデー タ (モ-ドワ-ド614の「未使用」)を含む。

【0010】ディスクリプタ毎にディスクリプタ管理用 のデータを用意することで、ソフトウェアによるディス クリプタの管理を容易に行なうことができる。

(4) 各ディスクリプタが、割込み信号の発生を指定す るデータ(モ-ドワ-ド614のCONT)を含み、転送制御手段 (400)は、各ディスクリプタから情報を読込むときに該 【0005】本発明は、現在、転送されているブロック 50 指定データをコントロールレジスタ(402)に書込んで、

10

情報を読込んだディスクリプタの情報に基づいた一単位 の転送の終了時に、該指定データに基づいて割込み信号 を発生する

- (5) ディスクリプタ毎に割り込みを発生させることができるDMAコントローラ。
- (6) ディスプリクタ毎に割り込み発生タイミングと再起動のタイミングを遅らせることができるDMAコントローラ。
- (7) ディスクリプタ内に動作に無関係なデータ(モード ワード614の「未使用」)を設けたことを特徴とする DMA コントローラ。

【0011】本発明の他の目的および特徴は、図面を参照した以下の実施例の説明より明らかになろう。

#### [0012]

【実施例】図1に本発明の一実施例の構成を示す。CPU100はマイクロプロセッサである。ROM200はCPU100が実行するプログラムを格納するリードオンリーメモリである。メモリコントローラ300はRAM600の制御信号を発生し、CPU100やDMAコントローラ400の要求に応じてRAM600に対して20リードやライトを行う回路である。DMAコントローラ400が、本発明の一実施例のDMA装置の主要部である。I/Oデバイス500はたとえばハードディスクのようなデータ転送の対象となるデバイスである。RAM600はリードライト可能なランダムアクセスメモリである。

【0013】DMAを行う前に、CPU100がRAM600にディスクリプタを用意する。図2に、RAM600上に2つのディスクリプタ610,620を生成した態様を示し、図3の(a)に、1つのディスクリプタ610の構造を示す。図2に示すようにディスクリプタを2つ生成したとすると、第1のディスクリプタ610のネクストディスクリプタポインタレジスタ611(メモリの1領域:1つのレジスタ)には、第2のディスクリプタ620の先頭アドレスが格納されている。

[0014]第2のディスクリプタ620の転送元アドレスレジスタ612のデータは、バッファメモリ①630の先頭のアドレスを示す。バッファメモリ①630には転送すべきデータが格納されている。第1のディスクリプタ610の転送バイト数レジスタ613には、バッ 40ファメモリ①630に格納されたデータのうち、転送すべきバイト数が格納されている。

【0015】第1のディスクリプタ610のモードワードレジスタ614の、最下位ビットすなわちビットNo.0には、この第1のディスクリプタ610で示される転送が終了したら、割り込みを発生するかどうかをきめるフラグデータCONTが存在し、これが「1」のとき、DMAコントローラ400が割り込み信号を発生する。同様に、第2のディスクリプタ620に示されるネクストディスクリプタポインタレジスタ621には、もし、

あれば第3のディスクリプタの先頭アドレスが格納されるが、図示例では、第2のディスクリプタ620は最後のディスクリプタなので、終了であることをDMAコントローラ400に教えるために、「0」が格納される。第2のディスクリプタ620の転送元アドレスレジスタ622はバッファメモリ②640には転送すべきデータが格納されている。第2のディスクリプタ620の転送バイト数レジスタ623にはバッファメモリ②640に格納されたデータのうち、転送すべきパイト数が格納されている。第2のディスクリプタ620のモードワードレジスタ624には、何も設定されていない。

【0016】従来のディスクリプタ方式のDMAでは、 最終ディスクリプタで示されるブロックを転送完了する と割り込みを発生していた。本実施例では、図3に示す ように、最終ディスクリプタの前のディスクリプタ61 O内に割り込みイネーブルビット「CONT」を設けること で、ディスクリプタ単位で割り込みを発生させることを できるようにした。ディスクリプタのサイズは何ワード でも、機能に問題はないがここでは4ワードとし、ディ スクリプタの先頭アドレスからの増分アドレスをオフセ ットとして図3の(a)に示す。ネクストディスクリプ タアドレスレジスタ611は、ディスクリプスタ61 0,620をチェーン構造にしてリンクしていけるよう に、次に実行すべきディスクリプスタ620のアドレス を格納する。転送元アドレスレジスタ612のデータ は、このディスクリプタ610がバッファメモリの63 0からⅠ/○デバイス500への転送を行うものとし て、RAMメモリ600上に確保された転送データ(6 30)の先頭アドレスを示す。転送バイト数レジスタ6 13のデータは転送すべき長さ(バイト数)を示す。 【0017】モードワードレジスタ614は、ディスク リブタ単位での動作モードを設定するためのワードを格 納し、詳細は図3の(b)に示す。モードワードレジス タ614は、この実施例の場合32bitの長さをも つ。その最下位ビットであるビットNo.0のデータCO NTは、「0」と「1」の2つの状態を取ることができ、 このBitデータCONTは割り込みイネーブルビットとし て機能する。割り込みイネーブルビットとは、このビッ トが「1」に設定されているディスクリプタの示す転送 が完了したら、割り込みを発生することを許可すること を示す。

【0018】図4の(a)に、DMAC(DMAコントローラ)400の構成を示す。ディスクリプタボインタレジスタ401は、RAMメモリ600上に格納されたディスクリプタ(610/620)の先頭アドレスを格納するためのレジスタである。コントロールレジスタ402は、CPU100からDMA動作開始の指示をうけるためのレジスタである。アドレスレジスタ403は、ディスクリプタが保持する転送元アドレスを格納するも

のであり、転送カウンタ409は実際の転送バイト数を カウントするカウンタである。転送バイト数レジスタ4 10はディスクリプタで示される転送バイト数を格納す るためのレジスタである。

【0019】DMA転送制御回路404は、アドレスレ ジスタ403の転送元アドレスと転送カウンタ409の カウント値(転送済バイト数)の和で示されるアドレス のメモリをアクセスし、実際の転送を行う回路である。 モードレジスタ406はディスクリプタのモードワード レジスタ614,624のデータを格納するためのレジ 10 スタである。ディスクリプタ制御回路405は、ディス クリプタ610、620の読み込みを行う回路である。 割込みイネーブル信号ライン407を介して、モードレ ジスタ406の割込み指示ビットCONTのデータ(「1」 又は「O」)がDMA転送制御回路404に与える。と れが転送完了時に割り込みを発生させるかどうかを知ら せる信号である。ディスクリプタで示される転送が完了 したときに、DMA転送制御回路404(DMAC40 0) は、割込み信号ライン408を介してCPU100 に対して割込みを知らせる信号を与える。

【0020】CPU100が、RAM600上に転送デ - タおよびディスクリプタを設定し、そして DMAC 4 00のディスクリプタポィンタレジスタ401に第1デ ィスクリプタの先端アドレスを書込み、コントロールレ ジスタ402の、図4の(c)に示すビットEXECに、

「1」を書くと、これに応答してDMAC400が転送 動作を開始する。

【0021】図5に、DMAC400の転送動作フロー を示す。開始701は、CPU100がDMAC400 のコントロールレジスタ402のEXECビットに「1」を 立てることで始まり、DMAC400はまずディスクリ プタ読み出し702に進む。すなわちメモリ上のディス クリプタを読み出しに行く。具体的には、DMAC40 0は、ディスクリプタポインタレジスタ401のデータ が示すアドレス(ディスクリプタ610)の内容を4ワ ード読み出して、最初のワード(ネクスディスクリプタ アドレス)を図4の(a)に示すネクストディスクリプ タポインタレジスタ411へ格納し、2番目のワード (転送元アドレス) はアドレスレジスタ403へ格納 し、3番目のワード(転送バイト数)は転送バイト数レ 40 ジスタ410へ格納し、4番目のワード(モードワー ド) はモードレジスタ406 およびコントロールレジス タ402へ格納する。その動作波形を図6に示す。 【0022】図6を参照すると、CLK信号はシステム の動作の基本となるクロック信号を示す。TRZ\_ST

ART信号はメモリに対するアクセスが開始されたこと

を示す。ADDRESS信号はメモリのアドレスを示

す。DATA信号はメモリが出力するデータ信号を示 す。RDWR信号はメモリに対するアクセスが読み出し の内部のレジスタのアドレスを示す。IRDWR信号は DMAC内部のアクセスが読み出しか書き込みかを示 す。IDATA信号はDMAC内部のデータを示す。I RDATA信号はIADDR信号で指定されたDMAC の内部レジスタの内容を示す信号である。

【0023】図6の**①**のCLK信号立ち上がりでは、T RZ\_START信号がアサートされて、アクセスが開 始されたことを示し、同時にADDRESS信号が有効 になり、RDWR信号がハイとなり、読み出しであるこ とを示している。2のクロック立ち上がりでは、そのA DDRESS信号を受けて、メモリはデータをDATA 信号に出力している。同時にDMACは内部の取り込む べきレジスタのアドレスをIADDR信号に出力し、I RDWR信号は内部レジスタに対する書き込みであると とを示している。そして、メモリのデータ(DATA) を内部のデータ(IDATA)として出力している。3 のクロック立ち上がりではDMACの内部のデータ(I DATA) から IADDR信号で示される内部レジスタ に取り込まれ、レジスタの内容がIRDATA信号に保 持されている。④のクロック立ち上がりはなにもないア イドルサイクルを示す。⑤のクロック立ち上がりは次の アクセスの開始を示す。この図では一回のメモリアクセ スは4クロックで行われる。以上により第1ディスクリ ブタ610の各レジスタ611~614の各データが、 DMAC400の各レジスタ411, 403, 410, 406に書込まれる。

【0024】次にDMAC400は、各レジスタ41 1,403,410,406のデータが規定するDMA 転送(703)を開始し、1つのディスクリプタ(第1 ディスクリプタ610)で指定されたブロックの転送が 完了したかどうかチェックする(704)。プロックの 転送が完了していなければ、次の転送のためにアドレス を更新する(705)。ブロックの転送が完了するま で、転送(703)を繰り返す。ブロックの転送が完了 すると、DMAC400は、ディスクリプタそのものの チェーンが完了した、すなわち全体の転送が完了した、 かどうかをチェックする(706)。

【0025】先に述べたが図示例では、第2のディスク リプタ620が最後のディスクリプタなので、終了であ ることをDMAコントローラ400に教えるために、

「0」がネクストディスクリプタポインタ621に書込 まれており、今転送を実行したディスクリプタが、仮に 最後のディスクリブタ(第2ディスクリブタ620)で あるとすると、DMAC400のネクストディスクリブ タポインタレジスタ411にはデータ「0」が書込まれ ているので、とのデータに基づいて、全体の転送が完了 した、と判定する(706)。

【0026】しかし、今終えた転送が第1ディスクリブ タ610のデータに基づくものであると、ネクストディ か書き込みかを示す。IADDR信号はDMAC400 50 スクリプタポインタレジスタ411には第1ディスクリ

30

プタ610のネクストディスクリプタポインタ611の データ(第2ディスクリプタ620の先頭アドレス)が あるので、DMAC400は、次のディスクリプタ(6 20)が有効であるので、モードレジスタ406に格納 している、元はモードワードレジスタ614にあったビ ットCONTの「1」をライン407経由で読んで、それが 「」」であるので、コントロールレジスタ402に書込 んでいるタイマ変数(元はモードワードレジスタ614 にあったデータ)を計時タイマに設定して計時を開始 みを発生する(707)。すなわち、DMAC400 は、コントロールレジスタ402のビットEXECを「0」 にクリアして、CPU100への割込要求ライン408 に割込み信号を与える(707)。そして、CPU10 0がこれに応答してコントロールレジスタ402のビッ トEXECを「1」にするのを待つ。そして、「1」になる と、第2ディスクリプタ620のデータを読込んでレジ スタ各レジスタ411, 403, 410, 406, 40 2に書込み(702)、転送(703)を行なう。 【0027】第2ディスクリプタ620のデータに基づ 20 いた転送を完了すると、ネクストディスクリプタポイン タレジスタ411のデータが「0」になっているので、 DMAC400は、完了割込み信号を発生して(-70 8)、全処理を完了する。

【0028】継続割込み(707)は、DMAC400 のコントロールレジスタのCONTビットが「1」(第1デ ィスクリプタ610)のとき、有効となるが「0」(第 2ディスクリプタ620)のときは、継続割込みは発生 しない。最終ディスクリプタ(620)中のモードワー ド(624)にもCONTビット相当のビットは存在する が、それは「0」とされ、コントロールレジスタ402 のCONTビットが「0」になるので、DMAC400は、 継続割込みは発生せず、完了割込み信号を発生する。 【0029】上述の実施例では、図3の(b)に示すよ

ろに、ディスクリプタのモードワードレジスタ614内\*

\* にタイマ変数を用意して、1ブロックの転送完了後タイ マ変数で指定した時間待ってから、継続割込みを発生す る。このタイマ変数にて、1ブロック転送完了から継続 割込み発生までの時間を設定することができる。最終デ ィスクリプタ(620)のモードワードレジスタ(62 4) にもタイマ変数を含めて、最終ブロックの転送完了 からその時間分の遅延の後に完了割込み信号を発生する ようにすることによって、完了割込みのタイミングも設 定可能になる。図3の(b)に示すように、ディスクリ し、タイマ変数が表わす時間が経過すると、継続の割込。10 プタのモードワードレジスタ614内に、ディスクリプ タによる転送制御には無関係の「未使用」ビットを用意 し、DMAC400がこれを使わないようにすること で、ソフトウェアによる該「未使用」ビットへの読み書 きが可能であり、ソフトウェアによるディスクリプタの 管理に使用することができる。

#### 【図面の簡単な説明】

【図1】 本発明の一実施例のDMAシステムの構成を 示すブロック図である。

【図2】 図1に示すRAM600上に設定されたディ スクリプタを模式的に示す図表である。

【図3】 (a)は図2に示す第1ディスクリプタ61 0のワード構成を模式的に示す図表、(b)は(a)に 示すモードワードレジスタ614のデータ構成を示す図 表である。

(a)は図1に示すDMAコントローラ40 【図4】 0の機能構成を示すブロック図、(b)は(a)に示す ディスクリプタポインタレジスタ401の格納データの 内容を示す図表であり、(c)はコントロールレジスタ 402の限納データの内容の一部を示す図表である。

【図5】 図4に示すDMAコントローラ400のDM A転送制御の概要を示すフローチャートである。

【図6】 図4に示すDMAコントローラ400がRA M600からデータを読込むときの読み書きデータおよ び制御信号の発生タイミングを示すタイムチャートであ

【図1】



【図3】



| データの内容 | タイマ変数 |         |    | 未使用 |    |      |   | CONT   |
|--------|-------|---------|----|-----|----|------|---|--------|
| LytNo. | 31    | · · · · | 16 | 17  |    | 2    | 1 | 0      |
|        |       |         |    |     | Ŧ. | ・ドワー | ۲ | _B 1 4 |
|        | (ь)   |         |    |     |    |      |   |        |

# BEST AVAILABLE COPY

(6)

特開2000-298640



,